<template>
  <div class="user-edit-container">
    <!-- Header 区域 -->
    <van-nav-bar
      title="编辑资料"
      left-arrow
      @click-left="$router.back()"
      fixed
    />

    <!-- 用户资料 -->
    <van-cell-group class="action-card">
      <van-cell title="头像" is-link center>
        <template #default>
          <van-image
            round
            class="avatar"
            :src="profileObj.photo"
            @click="imageClickFn"
          />
          <!-- file 选择框 -->
          <!-- 视觉上隐藏，标签还在DOM树上，还可以触发功能   accept="image/*" 限制文件格式-->
          <input
            type="file"
            ref="iptFile"
            v-show="false"

            accept="image/*"

            @change="onFileChange"
          />
        </template>
      </van-cell>
      <van-cell title="名称" is-link :value="profileObj.name" @click="UnName" />
      <van-cell title="生日" is-link :value="profileObj.birthday" @click="birthdayClickFn" />
    </van-cell-group>

       <!-- 姓名修改弹窗 -->
      <van-dialog
        v-model="show"
        title="标题"
        show-cancel-button
        :before-close="beforeCloseFn"
      >
        <input type="text" v-fofo v-model="inputUserName" />
      </van-dialog>

<!-- 时间选择器 -->
<!-- 组件可以自己搭配使用 -->
<van-popup round v-model="dateTimePickerShow" position="bottom" :style="{height:'50%'}">
<van-datetime-picker
  v-model="currentDate"
  type="date"
  title="选择年月日"
  :min-date="minDate"
  :max-date="maxDate"
  @cancel ="dateCancelFn"
  @confirm="confirmFn"
/>
</van-popup>
  </div>
</template>

<script>
import { userProfileAPI, undateUserPhotoAPI, updateUserProfileAPI } from '@/api'
import { Notify } from 'vant'
import { formatDate } from '@/utils/date.js'
export default {
  name: 'UserEdit',
  data () {
    return {
      profileObj: {}, // 用户基本资料
      inputUserName: null,
      show: false,
      minDate: new Date(1990, 1, 1), // 最小范围
      maxDate: new Date(), // 最大范围(默认获取系统日期-今日)
      currentDate: new Date(), // 当前时间
      dateTimePickerShow: false // 日期选择器-弹出层显示/隐藏
    }
  },
  async created () {
    const res = await userProfileAPI()
    console.log(res)
    this.profileObj = res.data.data
  },
  methods: {
    // 文件选择改变--事件
    async onFileChange (e) {
      console.log(e)
      if (e.target.files.length === 0) return // 用户可能没有选择图片文件阻止代码往下
      console.log(e.target.files[0])// （用户选中文件对象）数组其实是一个特殊的对象
      const theFd = new FormData()
      theFd.append('photo', e.target.files[0])// 请求体里加入一对参数名和值

      const res = await undateUserPhotoAPI(theFd)
      console.log(res)
      this.profileObj.photo = res.data.data.photo // 回显
    },

    // 图片--点击事件
    imageClickFn () {
      this.$refs.iptFile.click() // js模拟标签的事件触发，为了让input[file]窗口出现
    },
    UnName () {
      this.show = true
      this.inputUserName = this.profileObj.name
    },
    // 姓名 确认框 关闭回调函数
    async beforeCloseFn (action, done) {
      if (action === 'confirm') {
        // 点确定
        // 计算机中，对字符（文字）有多种编码方式
        // 计算机眼中只有0和1 编码成一种表现形式
        // utf-8编码成我们认识的中文字符
        // url编码  Unicode编码
        // u4e00 一    u9fa5 龥 （yu四声）
        const reg = /^[a-zA-Z0_9\u4e00-\u9fa5]{1,7}$/
        if (reg.test(this.inputUserName) === true) {
          // 通过了校验
          await updateUserProfileAPI({
            name: this.inputUserName
          })
          this.profileObj.name = this.inputUserName// 更新成功--回显到页面上
          done()
        } else {
          // 没通过给用户提示
          // 警告通知
          Notify({ type: 'warning', message: '用户名只能是1-7位中英数字组合' })
          done(false)
        }
      } else {
        // 点取消

        done()// 让弹窗关闭
      }
    },
    // 生日单元格--点击事件
    birthdayClickFn () {
      this.dateTimePickerShow = true// 时间选择器出现
      this.currentDate = new Date(this.profileObj.birthday)
    },
    // 日期选择器 -取消事件
    dateCancelFn () {
      this.dateTimePickerShow = false
    },
    // 日期选择器-完成确认时间
    async confirmFn (value) {
      // 日期选择器组件里currentDate是日期对象，而后端要的是年-月-日字符串
      await updateUserProfileAPI({
        birthday: formatDate(value)
      })
      this.dateTimePickerShow = false
      this.profileObj.birthday = formatDate(value)// 单元格同步
    }

  }
}
</script>

<style lang="less" scoped>
.user-edit-container {
  padding-top: 46px;
  .avatar {
    width: 50px;
    height: 50px;
  }
}
::v-deep .van-dialog__content {
  text-align: center;
  input {
    padding: 0;
    outline: none;
    border: none;
    text-align: center;
  }
}
</style>
